Eclipse 使用 jdk 11 时 找不到 java.sql 包的解决方法 您所在的位置:网站首页 import javatime报错 Eclipse 使用 jdk 11 时 找不到 java.sql 包的解决方法

Eclipse 使用 jdk 11 时 找不到 java.sql 包的解决方法

2024-05-08 23:24| 来源: 网络整理| 查看: 265

我本机是 jdk 11 ,在一次使用 Eclipse 开发时,偶然遇到了 import java.sql 报错的问题;由于平时都是用 Idea 做的,这可着实把我难住了。

后边经过排查,发现是 jre 的问题。众所周知,在 jdk 11 以及以后的 jdk 版本中(大概?)安装 jdk 是不会自动安装 jre 的,得手动生成,百度上查到的千篇一律,全都是

下边这个命令:

jlink.exe --module-path jmods --add-modules java.desktop --output jre

我就纳闷儿了,难道全都是复制粘贴,都没人出过错?用这个命令生成的 jre 在 Eclipse 里使用时,构建路径上只有几个包,根本没有 java.sql 因此就会导致无法 import java.sql (下图是解决问题后的截图,懒得复现了)

知道了问题 所在,解决方法也就很简单了,看下 jlink 的帮助就明白了

 

 

上边命令的错误就错在生成的 jre 没有添加 java.sql 模块,我们加进去就是。

最终命令如下:

jlink.exe --module-path jmods --add-modules java.sql,java.desktop --output jre

 

 现在就可以愉快的写 SQL 了

 

2021-6-30 Python 效率还是高啊,随手做了一份启用了所有 jmod 的命令( 基于 jdk 11 ):

jlink.exe --module-path jmods --add-modules java.base,java.compiler,java.datatransfer,java.desktop,java.instrument,java.logging,java.management,java.management.rmi,java.naming,java.net.http,java.prefs,java.rmi,java.scripting,java.se,java.security.jgss,java.security.sasl,java.smartcardio,java.sql,java.sql.rowset,java.transaction.xa,java.xml.crypto,java.xml,jdk.accessibility,jdk.aot,jdk.attach,jdk.charsets,jdk.compiler,jdk.crypto.cryptoki,jdk.crypto.ec,jdk.crypto.mscapi,jdk.dynalink,jdk.editpad,jdk.hotspot.agent,jdk.httpserver,jdk.internal.ed,jdk.internal.jvmstat,jdk.internal.le,jdk.internal.opt,jdk.internal.vm.ci,jdk.internal.vm.compiler,jdk.internal.vm.compiler.management,jdk.jartool,jdk.javadoc,jdk.jcmd,jdk.jconsole,jdk.jdeps,jdk.jdi,jdk.jdwp.agent,jdk.jfr,jdk.jlink,jdk.jshell,jdk.jsobject,jdk.jstatd,jdk.localedata,jdk.management.agent,jdk.management.jfr,jdk.management,jdk.naming.dns,jdk.naming.ldap,jdk.naming.rmi,jdk.net,jdk.pack,jdk.rmic,jdk.scripting.nashorn,jdk.scripting.nashorn.shell,jdk.sctp,jdk.security.auth,jdk.security.jgss,jdk.unsupported.desktop,jdk.unsupported,jdk.xml.dom,jdk.zipfs --output jre

 



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有